草庐IT

SQL IN 子句比单个查询慢

全部标签

ruby-on-rails - 将参数值传递给 redirect_to 作为 rails 中的查询字符串

这应该很简单,但我似乎找不到简单的答案。如何将当前请求的参数值传递到redirect_to调用中?我有一些表单值想传递到GET重定向的查询字符串中我想做这样的事情:redirect_to@thing,:foo=>params[:foo]并发送到:http://things/4?[foo][key1]=val1&[foo][key2]=val2谢谢!此外-对于redirect_to:back如何处理?redirect_to:back,:foo=>params[:foo] 最佳答案 redirect_to的“记录”形式仅将第二个参数用于

ruby-on-rails - 如何使用 AREL 执行条件 where 子句

如何做一个有条件的where子句?我有一个运行查询的rake任务。假设我正在构建这样的查询:residentials=Residential.where(:is_active=>true)现在,如果我将某个参数传递给rake任务,我想添加到where子句中。我在想这样的事情:residentials.where(:something_else=>true)ifparam_was_passed但这只是替换了现有的where子句。如何将它添加到现有的where子句中? 最佳答案 可以链接where语句residentials=Resid

Ruby 将所有空格减少为单个空格

我不确定该怎么做,因为我对正则表达式还很陌生,而且似乎找不到合适的方法来完成这个但是说我有以下字符串(所有制表符和换行符包括)1/2cuponion(chopped)如何删除所有空格并仅用一个空格替换每个实例? 最佳答案 在这种情况下,正则表达式可以很好地工作,因为您希望对整个类别的空白字符一视同仁,并用单个空白字符替换空白字符的任意组合。因此,如果该字符串存储在s中,那么您将执行:fixed_string=s.gsub(/\s+/,'') 关于Ruby将所有空格减少为单个空格,我们在S

sql - 通过关联的 Rails 查询仅限于最近的记录?

classUserhas_many:books我需要一个返回的查询:最近一本书具有:complete=>true的用户。即,如果用户最近的书有:complete=>false,我不希望它们出现在我的结果中。到目前为止我有什么User.joins(:books).merge(Book.where(:complete=>true))这是一个很有希望的开始,但没有给我需要的结果。我试过添加.order("created_ondesc").limit(1)到上述查询的末尾,但是当我期待很多结果时,我最终只得到一个结果。谢谢! 最佳答案 如果

ruby-on-rails - Rails ActiveRecord 查询日期范围

我正在尝试在我的Controller中使用以下行来捕获从当前日期起不到一周的所有任务:@due_this_week=current_user.tasks.where(due_date:Date.today..1.week.from_now)出于某种原因,它没有找到任何结果,即使我知道我有四到六天的任务到期。这是唯一使用范围查询的实例变量。我有另一个可以很好地查找逾期任务的工具:@overdue=current_user.tasks.where("due_date我错过了什么? 最佳答案 应该是:@due_this_week=curr

ruby - 如何使用 Ruby 测试/单元执行单个测试?

有什么方法可以在ruby​​测试/单元框架下执行单个测试,而不是自动运行所有测试用例。我知道我可以通过使用Rake来实现这一点,但我现在还没有准备好切换到rake。rubyunit_test.rb#thiswillrunallthetestcaserubyunit_test.rbtest1#thiswillonlyruntest1 最佳答案 您可以在命令行上传递-n选项来运行单个测试:rubymy_test.rb-ntest_my_method其中“test_my_method”是您要运行的测试方法的名称。

ruby-on-rails - ActiveRecord 查询中的 “includes” 和 “preload” 有什么区别?

我正在努力寻找ActiveRecord对象的includes()和preload()的比较。谁能解释一下区别? 最佳答案 Rails有两种方法可以避免n+1问题。一个涉及创建一个基于大连接的查询以拉入您的关联,另一个涉及为每个关联进行单独的查询。当您执行includes时,rails会决定为您使用哪种策略。它默认使用单独的查询方法(预加载),除非它认为您正在使用条件或订单中关联的列。因为这只适用于joins方法,所以改用它。Rails的启发式方法有时会出错,或者您可能有特定的原因偏爱一种方法而不是另一种方法。preload(及其配套

ruby - 使用 lambda 在单个实例上重新定义单个 ruby​​ 方法

在Ruby中,有没有办法使用proc重新定义类的特定实例的方法?例如:classFoodefbar()return"hello"endendx=Foo.newy=Foo.new(类似的东西):y.method(:bar)=lambda{return"goodbye"}x.bary.bar制作:hellogoodbye谢谢。 最佳答案 defdefine_singleton_method_by_proc(obj,name,block)metaclass=class或者,如果你想猴子修补对象以使其变得容易classObject#note

ruby-on-rails - 如何使用 Rails 中的 instance_eval 子句删除验证?

我想使用instance_eval增强现有类。原始定义包含验证,这需要存在某些字段,即:classDummytrueend现在我想使用instance_eval(或任何其他方法,真的)将其更改为可选:Dummy.instance_evaldo...end删除验证的正确语法是什么,因此该字段是可选的。我宁愿直接在模型层上这样做,而不是在Controller或View中进行奇怪的修改。instance_eval的使用并不是真正必需的,但据我所知,这通常是增强Rails类的最佳方式。编辑#1一般来说-原始类是gem的一部分,我不想fork它,也不想绑定(bind)到特定版本。一般原因并不重要

ruby-on-rails - 如何在 guard for rspec 中运行单个测试?

我使用guard-rspec在我的文件更改时自动运行必要的rspec测试,我喜欢它的工作方式。但是,当我调试包含多个测试的文件时,有时我只想重新运行单个测试。例如,从命令行使用rspec:rspecspec/requests/my_favorite_spec.rb:100这将仅运行my_favorite_spec.rb中第100行的单个规范。我尝试将以上内容输入守卫控制台,但它只是运行了所有测试,就好像我刚刚按下回车键一样。守卫控制台中是否有另一种语法来运行单个规范? 最佳答案 您必须参数化您的spec/spec_helper.rb